<!--部门选择组件-->
<template>
  <div>
    <JSelectBiz @handleOpen="handleOpen" :loading="loadingEcho" v-bind="attrs" @change="handleChange" />
    <DeptSelectModal @register="regModal" @getSelectResult="setValue" v-bind="getBindValue" :multiple="multiple" />
  </div>
</template>
<script lang="ts">
  import DeptSelectModal from './modal/DeptSelectModal.vue'
  import JSelectBiz from './base/JSelectBiz.vue'
  import { defineComponent, ref, reactive, watchEffect, watch, provide, unref, toRaw } from 'vue'
  import { useModal } from '/@/components/Modal'
  import { propTypes } from '/@/utils/propTypes'
  import { useRuleFormItem } from '/@/hooks/component/useFormItem'
  import { useAttrs } from '/@/hooks/core/useAttrs'
  import { SelectValue } from 'ant-design-vue/es/select'

  export default defineComponent({
    name: 'JSelectDept',
    components: {
      DeptSelectModal,
      JSelectBiz,
    },
    inheritAttrs: false,
    props: {
      value: propTypes.oneOfType([propTypes.string, propTypes.array]),
      // 是否允许多选，默认 true
      multiple: propTypes.bool.def(true),
    },
    emits: ['options-change', 'change', 'select', 'update:value'],
    setup(props, { emit, refs }) {
      const emitData = ref<any[]>()
      //注册model
      const [regModal, { openModal }] = useModal()
      //表单值
      const [state] = useRuleFormItem(props, 'value', 'change', emitData)
      //下拉框选项值
      const selectOptions = ref<SelectValue>([])
      //下拉框选中值
      let selectValues = reactive<Recordable>({
        value: [],
      })
      // 是否正在加载回显数据
      const loadingEcho = ref<boolean>(false)
      //下发 selectOptions,xxxBiz组件接收
      provide('selectOptions', selectOptions)
      //下发 selectValues,xxxBiz组件接收
      provide('selectValues', selectValues)
      //下发 loadingEcho,xxxBiz组件接收
      provide('loadingEcho', loadingEcho)

      const tag = ref(false)
      const attrs = useAttrs()

      /**
       * 监听组件值
       */
      watchEffect(() => {
        props.value && initValue()
      })

      //update-begin-author:liusq---date:20220609--for: 为了解决弹窗form初始化赋值问题 ---
      watch(
        () => props.value,
        () => {
          initValue()
        }
      )
      //update-end-author:liusq---date:20220609--for: 为了解决弹窗form初始化赋值问题 ---
      /**
       * 监听selectValues变化
       */
      watch(selectValues, () => {
        if (selectValues) {
          state.value = selectValues.value
        }
      })
      /**
       * 监听selectOptions变化
       */
      watch(selectOptions, () => {
        if (selectOptions.value) {
          emit('select', toRaw(unref(selectOptions)), toRaw(unref(selectValues)))
        }
      })

      /**
       * 打卡弹出框
       */
      function handleOpen() {
        tag.value = true
        openModal(true, {
          isUpdate: false,
        })
      }

      /**
       * 将字符串值转化为数组
       */
      function initValue() {
        let value = props.value ? props.value : []
        if (value && typeof value === 'string') {
          state.value = value.split(',')
          selectValues.value = value.split(',')
        } else {
          // 【VUEN-857】兼容数组（行编辑的用法问题）
          selectValues.value = value
        }
      }

      /**
       * 设置下拉框的值
       */
      function setValue(options, values) {
        selectOptions.value = options
        //emitData.value = values.join(",");
        state.value = values
        selectValues.value = values
        emit('update:value', values.join(','))
      }
      const getBindValue = Object.assign({}, unref(props), unref(attrs))

      //update-begin---author:wangshuai ---date:20230406  for：【issues/397】在表单中使用v-model:value绑定JSelectDept组件时无法清除已选择的数据------------
      /**
       * 值改变事件更新value值
       * @param values
       */
      function handleChange(values) {
        emit('update:value', values)
      }
      //update-end---author:wangshuai ---date:20230406  for：【issues/397】在表单中使用v-model:value绑定JSelectDept组件时无法清除已选择的数据------------

      return {
        state,
        attrs,
        selectOptions,
        selectValues,
        loadingEcho,
        getBindValue,
        tag,
        regModal,
        setValue,
        handleOpen,
        handleChange,
      }
    },
  })
</script>
<style lang="less" scoped>
  .j-select-row {
    @width: 82px;

    .left {
      width: calc(100% - @width - 8px);
    }

    .right {
      width: @width;
    }

    .full {
      width: 100%;
    }

    :deep(.ant-select-search__field) {
      display: none !important;
    }
  }
</style>
